<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>p2_外间距测试</title>
    <style>
        /*去掉页面默认外边距*/
        body {
            margin: 0;
        }
        /*去掉所有元素自带的外间距*/
        * {
            margin: 0;
            padding: 0;
        }
        /*父子贴边：首个子元素的上边距和最后一个子元素的下边距会超出父元素的范围
        设置bfc保护*/
        .fu{
            background-color: rgba(255,255,0,.3);

        }
        .fu>div{
            width: 100px;
            height: 100px;
            background-color: rgba(0,0,255,.6);
            border:2px solid #00f;
            color: #fff;
            font-size: 25px;
            font-weight: bold;
        }
        .z1{
            margin-top: 50px;
            margin-bottom: 30px;
        }
        /*相邻兄弟在垂直方向上的间距取最大值显示，不会叠加*/
        .z2{
            margin-top: 50px;
        }

        .z3{
            margin:10px;/*四个方向都是10px*/
            margin:10px 20px;/*上下10px 左右20px*/
            margin:10px 20px 30px;/*上10px 左右20px 下30px*/
            margin:10px 20px 30px 40px;/*上10px 右20px 下30px 左40px*/
            /*实现块级元素自身的水平居中auto会自动将左右外边距计算成等值*/
            margin: 0 auto;
        }
        span{
            border:1px solid red;
        }
        .s2{
            /*行内元素垂直方向上的外间距不生效*/
            margin: 50px;
        }
    </style>
</head>
<body>
<span>span</span><span class="s2">span</span><span>span</span>
<div class="fu">
    <div class="z1">子元素1</div>
    <div class="z2">子元素2</div>
    <div class="z3">子元素3</div>
    <div class="z4">子元素4</div>
</div>
</body>
</html>